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Amendments to the Claims: 

This listing of claims will replace all prior versions, and listings, of claims in the 
application: 

Listing of Claims: 

Claims 1-2 (canceled) 

3. (currently amended): A method for loop-free multipath routing of data in a 
network, comprising: 

(a) maintaining at each node i in a network, 

(i) a main distance table (MDT) containing and pj , where Dj is 

the distance of node / to destination / and p^ is the predecessor to destination 
j on the shortest path from / to j , 

(ii) said MDT further containing, for each destination j , successor set 
Sj , feasible distance FD' Jt reported distance RDj, and flags designated as 
changed and report — it , 

(iii) a main link table (MLT) T f which is the node's view of the network 
and contains links represented by (m, n, d) where (m, n)\sa link with cost d , 

(iv) a neighbor distance table (NDT) for neighbor k containing D) k and 

p) k where D' Jk is the distance of neighbor k to j as communicated by k and 
Pj k is the predecessor to j on the shortest path from k to j as notified by k f 

(v) a neighbor link table (NLT)r A ' which is the view that neighbor k has 

of the network as known to i and contains link information derived from the 
distance and predecessor information in the NDT, and 
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(vi) an adjacent link table (ALT) containing the cost l[ of an adjacent 

link to each neighbor k p wherein said cost is infinity if a link is down; [[and]] 

(b) in response to receipt of an update message M from a neighbor k, 
detection of a change in cost of an adjacent link to k , or detection of a change in status 
of an adjacent link to k , 

(i) updating the NDTand NLT for neighbor k with links (m, n, d) 
where d = - and m = p' nk , and 

(ii) constructing an MLT for neighbor k by merging topologies Tl and 
adjacent links l[ ; and 

wh e r ei n a l oop froo rout e for transmitt i ng th e dat a through th e n e twork is 
d e t e rmin e d 

(c) routing data through a loop-free path in the network; 

wherein at least one said loop-free path is determined using information in each 
of said tables at each node i . 

4. (currently amended): A method as recited in claim 3, further comprising: 
(o) (cQ for each destination /marked as changed , adding an update entry 

[ j\D'j* Pj~\ t0 a new message M % \ and 

(d) (el within a finite amount of time, sending message M to each neighbor k . 

5. (original): A method as recited in claim 4 f wherein an update message 
comprises: 

at least one update entry; 
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said update entry comprising a triplet [j,d,p] t where d is the distance of the 
node sending the message to destination j and p is the predecessor on the path to j ; 
and 

flags for synchronization designated as query and reply. 

6. (original): A method as recited in claim 3, further comprising: 

updating the MLT with link information reported by the neighbor k that offers the 
shortest distance from the node / to the head node m of the link if two or more NLTs 
contain conflicting information of link (m, n). 

7. (original): A method as recited in claim 3, further comprising: 

after merging topologies Tl and adjacent links 1[ , running Dijkstra's shortest 
path algorithm to find the shortest path tree and deletes all links from the MLT that are 
not in the tree. 

8. (original): A method as recited in claim 7, further comprising: 
obtaining distances D) and predecessors p) from the MLT. 

9. (original): A method as recited in claim 8, further comprising: 
comparing the tree with the previous shortest path tree and reporting only the 

differences to the neighbors. 

10. (original): A method as recited in claim 3, further comprising: 
computing a successor setSj by, for each destination allowing a node / to 

choose a successor having a distance to j as known to i that is less than the distance 
of node / to destination j that is known to a neighbor of node i . 
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1 1 . (original): A method as recited in claim 10, further comprising 
synchronizing the exchange of update messages among neighbors using query and 
reply flags contained within the messages. 

12. (original): A method as recited in claim 11, wherein if a node sends a 
message with a query flag set, said node must wait until a reply is received from all of 
said node's neighbors before said node is allowed to send the next update message. 

13. (original): A method as recited in claim 12, wherein said node is deemed 
to be in an ACTIVE state when said node sends a message with a query flag set. 

14. (original): A method as recited in claim 13, wherein said node is deemed 
to be in a PASSIVE state when said node has no message with a query flag set that is 
in transit or pending to be processed. 

15. (currently amended): A method as recited in claim 14: 

wherein if a node in a PASSIVE state receives an event resulting in changes in 
its distances to a destination, before the node sends an update message to report a 
new distance, said node checks if the distance D\ to any destination j has increased 

above the previously reported distance RD) \ [[and]] 

wherein if no distance has increased, then said node remains in a PASSIVE 
state; and 

wherein if a distance has increased, said node sets the query flag in the update 
message, sends said message, and goes into an ACTIVE state. 
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16. (previously presented): A method as recited in claim 13: 

wherein a node in an ACTIVE state cannot send any update messages or add 
neighbors to any successor set; 

wherein after receiving replies from all its neighbors, the node is allowed to 
modify the successor sets and report any changes that may have occurred since the 
time it has transitioned to ACTIVE state; and 

wherein if none of the distances increased beyond the reported distance, the 
node transitions to PASSIVE state. 

17. (original): A method as recited in claim 14: 

wherein if a node receives a message with the query flag set when in PASSIVE 
state, said node modifies said node's tables and sends back an update message with 
the reply Hag set; and 

wherein if a node receives a message with the query flag set when in ACTIVE 
stage, said node modifies said node's tables and sends back an empty message with 
no updates and with the reply flag set. 

18. (currently amended): A method for loop-free multipath routing of data in a 
network, comprising: 

(a) maintaining at each node i in a network, 

(i) a main distance table (MDT) containing and p) , where D) is 

the distance of node / to destination j and pj is the predecessor to destination 
j on the shortest path from / to j , 

(ii) said MDT further containing, for each destination j , successor set 
S' Jt feasible distance FD' Jt reported distance RD' J9 and flags designated as 
changed and report -it, 
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(iii) a main link table (MLT) T l which is the node's view of the network 
and contains links represented by (m, n t d) where (m , n)\$a link with cost d , 

(iv) a neighbor distance table (NDT) for neighbor k containing D) k and 

p' Jle where D' Jk is the distance of neighbor k to j as communicated by k and 
Pj k is the predecessor to j on the shortest path from k to j as notified by k , 

(v) a neignbor link table (NLT)r/ which is the view that neighbor k has 
of the network as known to i and contains link information derived from the 
distance and predecessor information in the NDT, and 

(vi) an adjacent link table (ALT) containing the cost V k of an adjacent 

link to each neighbor k , wherein said cost is infinity if a link is down; 

(b) in response to receipt of an update message M from a neighbor k , 
detection of a change in cost of an adjacent link to Jt , or detection of a change in status 
of an adjacent link to k , 

(i) updating the NDT and NLT for neighbor k with links (m, n, d) 
where d = D'^ - D? mk and m = p^, and 

(ii) constructing an MLT for neighbor k by merging topologies 7*/ and 
adjacent links V k ; 

(c) for each destination j marked as changed, adding an update entry 
[/,/)',, /?}] to a new message M \ [[and]] 

(d) within a finite amount of time, sending message M'to each neighbor k ; 

and 

wh e r e in a l oop - fr ee rout e for transmitt i ng th e data through tho network is 
d e t e rmin e d 

te) routing data through a loop-free path in the network: 
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wherein at least one said loop-free path is determined using information in each 
of said tables at each node / . 

19. (original): A method as recited in claim 18, wherein an update message 
comprises: 

at least one update entry; 

said update entry comprising a triplet [j 9 d 9 p] 9 where d is the distance of the 
node sending the message to destination j and p is the predecessor on the path to j ; 
and 

flags for synchronization designated as query and reply . 

20. (original): A method as recited in claim 18, further comprising: 
updating the MLT with link information reported by the neighbor k that offers the 

shortest distance from the node / to the head node m of the link if two or more 
neighbor link tables contain conflicting information of link (m , n). 

21 . (original): A method as recited in claim 18, further comprising: 

after merging topologies T* k and adjacent links V k , running Dijkstra's shortest 
path algorithm to find the shortest path tree and deletes all links from the MLT that are 
not in the tree. 

22. (original): A method as recited in claim 21 , further comprising: 
obtaining distances Dj and predecessors p) from the MLT. 
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23. (original): A method as recited in claim 22, further comprising: 
comparing the tree with the previous shortest path tree and reporting only the 

differences to the neighbors. 

24. (currently amended): A method for loop-free multipath routing of data in a 
network, comprising: 

(a) maintaining at each node / in a network, 

(i) a main distance table (MDT) containing D\ and pj , where D) is 

the distance of node / to destination j and is the predecessor to destination 
j on the shortest path from i to j , 

(ii) said MDT further containing, for each destination j , successor set 
Sj, feasible distance FD), reported distance RD^ and flags designated as 
changed and report - it , 

(iii) a main link table (MLT) T which is the node's view of the network 
and contains links represented by (m , rt, d) where (m , n) is a link with cost d , 

(iv) a neighbor distance table (NDT) for neighbor k containing D' Jk and 

p $ Jt where D' Jk is the distance of neighbor k to j as communicated by k and 
Pj k is the predecessor to j on the shortest path from k to j as notified by k , 

(v) a neighbor link table (NLT)r/ which is the view that neighbor k has 

of the network as known to / and contains link information derived from the 
distance and predecessor information in the NDT, and 

(vi) an adjacent link table (ALT) containing the cost V k of an adjacent 
link to each neighbor wherein said cost is infinity if a link is down; 
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(b) in response to receipt of an update message M from a neighbor k , 
detection of a change in cost of an adjacent link to k , or detection of a change in status 
of an adjacent link to k, 

(i) updating the NDTand NLT for neighbor k with links (m, «, d) 
where d = - D? mk and m = p' nk , 

(ii) constructing an MLTfor neighbor k by merging topologies T k * and 
adjacent links l' k ; [[and]] 

(c) computing a successor set Sj by, for each destination j , allowing a node 
i to choose a successor having a distance to j as known to / that is less than the 
distance of node / to destination j that is known to a neighbor of node / ; and 

wh e r e in a loop froo routo for tranom i tt i ng th e data through tho network i s 
d e t e rm i n e d 

(d) routing data through a loop-free path in the network; 

wherein at least one said loop-free path is determined using information in said 
tables at each node L 

25. (original): A method as recited in claim 24, further comprising: 
updating the MLT with link information reported by the neighbor k that offers the 

shortest distance from the node / to the head node m of the link if two or more NLTs 
contain conflicting information of link (m, n). 

26. (original): A method as recited in claim 24, further comprising: 

after merging topologies T k and adjacent links /{ , running Dijkstra's shortest 
path algorithm to find the shortest path tree and deletes all links from the MLT that are 
not in the tree. 
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27. (original): A method as recited in claim 26, further comprising: 
obtaining distances D) and predecessors p f y from the MLT. 

28. (original): A method as recited in claim 27, further comprising: 
comparing the tree with the previous shortest path tree and reporting only the 

differences to the neighbors. 

29. (original): A method as recited in claim 24, further comprising 
synchronizing the exchange of update messages among neighbors using query and 
reply flags contained within the messages. 

30. (original): A method as recited in claim 29, wherein if a node sends a 
message with a query flag set, said node must wait until a reply is received from all of 
said node's neighbors before said node is allowed to send the next update message. 

31. (original): A method as recited in claim 30, wherein said node is deemed 
to be in an ACTIVE state when said node sends a message with a query flag set. 

32. (original): A method as recited in claim 31 , wherein said node is deemed 
to be in a PASSIVE state when said node has no message with a query flag set that is 

in transit or pending to be processed. 

33. (currently amended): A method as recited in claim 32: 

wherein if a node in a PASSIVE state receives an event resulting in changes in 
its distances to a destination, before the node sends an update message to report a 
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new distance, said node checks if the distance Dj to any destination / has increased 
above the previously reported distance RDj \ [[and]] 

wherein if no distance has increased, then said node remains in a PASSIVE 
state; and 

wherein if a distance has increased, said node sets the query flag in the update 
message, sends said message, and goes into an ACTIVE state. 

34. (original): A method as recited in claim 31 , wherein a node in an ACTIVE 
cannot send any update messages or add neighbors to any successor set. 

35. (original): A method as recited in claim 31 : 

wherein after receiving replies from all its neighbors, the node is allowed to 
modify the successor sets and report any changes that may have occurred since the 
time it has transitioned to ACTIVE state; and 

wherein if none of the distances increased beyond the reported distance, the 
node transitions to PASSIVE state. 

36. (original): A method as recited in claim 32: 

wherein if a node receives a message with the query flag set when in PASSIVE 
state, said node modifies said node's tables and sends back an update message with 
the reply flag set; and 

wherein if a node receives a message with the query flag set when in ACTIVE 
stage, said node modifies said node's tables and sends back an empty message with 
no updates and with the reply flag set. 
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37. (currently amended): A method for loop-free multipath routing of data in a 
network, comprising: 

(a) maintaining at each node / in a network, 

(i) a main distance table (MDT) containing and p' Jt where D) is 

the distance of node / to destination j and p) is the: predecessor to destination 
j on the shortest path from i to j , 

(ii) said MDT further containing, for each destination j , successor set 
S f Jt feasible distance FDj, reported distance RDj t and flags designated as 
changed and report — it, 

(iii) a main link table (MLT) T which is the node's view of the network 
and contains links represented by ( m , n , d) where (m , n ) is a link with cost d , 

(iv) a neighbor distance table (NDT) for neighbor k containing Dj k and 

p f Jk where D' Jk is the distance of neighbor k to j as communicated by k and 
p f jk is the predecessor to j on the shortest path from k to j as notified by k , 

(v) a neighbor link table (NLT)?;' which is the view that neighbor k has 

of the network as known to / and contains link information derived from the 
distance and predecessor information in the NDT, and 

(vi) an adjacent link table (ALT) containing the cost l* k of an adjacent 

link to each neighbor k , wherein said cost is infinity if a link is down; 

(b) in response to receipt of an update message M from a neighbor k , 
detection of a change in cost of an adjacent link to k , or detection of a change in status 
of an adjacent link to k , 

(i> updating the NDT and NLT for neighbor k with links (m, n, d) 
where d = U nX - U ml and m = 
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. (ii) constructing an MLTfor neighbor k by merging topotogies T* and 

adjacent links l[ , and 

(iii) running Dijkstra's shortest path algorithm to find the shortest path 
tree and deletes all links from the MLT that are not in the tree; [[and]] 

(c) computing a successor sets) by, for each destination / , allowing a node 

i to choose a successor having a distance to j as known to i that is less than the 

distance of node /to destination j that is known to a neighbor of node i ; and 

wh e r e in a l oop fr ee rout e for transm i tt i ng th e data through th e n e twork i s 
dotorminod 

(d) routing data through a loop-free path in the network; 

wherein at least one said loop-free path is determined using information in said 
tables at each node / . 

38. (original): A method as recited in claim 37, further comprising: 
updating the MLT with link information reported by the neighbor k that offers the 

shortest distance from the node / to the head node m of the link if two or more NLTs 
contain conflicting information of link (m , n). 

39. (original): A method as recited in claim 38, further comprising: 
obtaining distances D\ and predecessors p\ from the MLT. 

40. (original): A method as recited in claim 39 t further comprising: 
comparing the tree with the previous shortest path tree and reporting only the 

differences to the neighbors. 
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41. (original): A method as recited in claim 37, further comprising 
synchronizing the exchange of update messages among neighbors using query and 
reply flags contained within the messages. 

42. (original): A method as recited in claim 41 , wherein if a node sends a ■ 
message with a query flag set, said node must wait until a reply is received from all of 
said node's neighbors before said node is allowed to send the next update message. 

43. (original): A method as recited in claim 42, wherein said node is deemed 
to be in an ACTIVE state when said node sends a message with a query flag set. 

44. (original): A method as recited in claim 43, wherein said node is deemed 
to be in a PASSIVE state when said node has no message with a query flag set that is 
in transit or pending to be processed. 

45. (currently amended): A method as recited in claim 44: 

wherein if a node in a PASSIVE state receives an event resulting in changes in 
its distances to a destination, before the node sends an update message to report a 
new distance, said node checks if the distance Dj to any destination j has increased 

above the previously reported distance RDj] [[and]] 

wherein if no distance has increased, then said node remains in a PASSIVE 
state; and 

wherein if a distance has increased, said node sets the query flag in the update 
message, sends said message, and goes into an ACTIVE state. 
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46. (original): A method as recited in claim 43, wherein a node in an ACTIVE 
cannot send any update messages or add neighbors to any successor set. 

47. (original): A method as recited in claim 43: 

wherein after receiving replies from all its neighbors, the node is allowed to 
modify the successor sets and report any changes that may have occurred since the 
time it has transitioned to ACTIVE state; and 

wherein if none of the distances increased beyond the reported distance, the 
node transitions to PASSIVE state. 

48. (original): A method as recited in claim 44: 

wherein if a node receives a message with the query flag set when in PASSIVE 
state, said node modifies said node's tables and sends back an update message with 
the reply flag set; and 

wherein if a node receives a message with the query flag set when in ACTIVE 
stage, said node modifies said node's tables and sends back an empty message with 
no updates and with the reply flag set. 

49. (currently amended): A method for loop-free muftipath routing of data in a 
network, comprising: 

(a) maintaining at each node i in a network, 

(i) a main distance table (MDT) containing Z>j and p) , where D) is 

the distance of node / to destination j and pj is the predecessor to destination 
j on the shortest path from Mo j % 
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(ii) said MDT further containing, for each destination j , successor set 
Sj , feasible distance FD' Jt reported distance RD* Jt and flags designated as 
changed and report -it t 

(iii) a main link table (MLT) 7" which is the node's view of the network 
and contains links represented by (m , n, d) where ( m , n) '\$a link with cost d , 

(iv) a neighbor distance table (NDT) for neighbor k containing Dj t and 

p) k where D) k is the distance of neighbor k to j as communicated by k and 
p' Jk is the predecessor to j on the shortest path from k to j as notified by k , 

(v) a neighbor link table (NLT)r/ which is the view that neighbor k has 

of the network as known to / and contains link information derived from the 
distance and predecessor information in the NDT, and 

(vi) an adjacent link table (ALT) containing the cost l' h of an adjacent 

link to each neighbor k , wherein said cost is infinity if a link is down; 

(b) in response to receipt of an update message M from a neighbor k, 
detection of a change in cost of an adjacent link to k , or detection of a change in status 
of an adjacent link to k , 

(i) updating the NDT and NLT for neighbor k with links (m, n t d) 
where d = D'^ - E? mk and m = p { Rk , 

(ii) constructing an MLT for neighbor k by merging topologies T k and 
adjacent links V k ; 

(c) computing a successor sets) by, for each destination / , allowing a node 
i to choose a successor having a distance to j as known to i that is less than the 
distance of node fto destination ythat is known to a neighbor of node /; [[and]] 
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(d) synchronizing the exchange of update messages among neighbors using 
query and reply flags contained within the messages; and 

wh e r e in a l oop fr ee rout e for transm i tt i ng th e data through th e n e twork is 
det e rm i n e d 

(e) routing data through a loop-free path in the network; 

wherein at least one said loop-free path is determined using information in said 
tables at each node i . 

50. (original): A method as recited in claim 49, further comprising: 
updating the MLT with link information reported by the neighbor k that offers the 

shortest distance from the node / to the head node m of the link if two or more NLTs 
contain conflicting information of link (m, n). 

51 . (original): A method as recited in claim 49, further comprising: 

after merging topologies T[ and adjacent links V k , running Dijkstra's shortest 

path algorithm to find the shortest path tree and deletes all links from the MLT that are 
not in the tree. 

52. (original): A method as recited in claim 51 , further comprising: 
obtaining distances £>) and predecessors p* s from the MLT. 

53. (original): A method as recited in claim 52, further comprising: 
comparing the tree with the previous shortest path tree and reporting only the 

differences to the neighbors. 
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54. (original): A method as recited in claim 49, wherein if a node sends a 
message with a query flag set, said node must wait until a reply is received from all of 
said node's neighbors before said node is allowed to send the next update message. 

55. (original): A method as; recited in claim 54, wherein said node is deemed 
to be in an ACTIVE state when said node sends a message with a queryflag set. 

56. (original): A method as recited in claim 55, wherein said node is deemed 
to be in a PASSIVE state when said node has no message with a query flag set that is 
in transit or pending to be processed. 

57. (currently amended): A method as recited in claim 56: 

wherein if a node in a PASSIVE state receives an event resulting in changes in 
its distances to a destination, before the node sends an update message to report a 
new distance, said node checks if the distance D) to any destination / has increased 

above the previously reported distance RD^ ; [[and]] 

wherein if no distance has increased, then said node remains in a PASSIVE 
state; and 

wherein if a distance has increased, sard node sets the query flag in the update 
message, sends said message, and goes into an ACTIVE state. 

58. (original): A method as recited in claim 55, wherein a node in an ACTIVE 
cannot send any update messages or add neighbors to any successor set. 
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59. (original): A method as recited in claim 55: 

wherein after receiving replies from all its neighbors, the node is allowed to 
modify the successor sets and report any changes that may have occurred since the 
time it has transitioned to ACTIVE state; and 

wherein if none of the distances increased beyond the reported distance, the 
node transitions to PASSIVE state. 

60. (original): A method as recited in claim 56: 

wherein if a node receives a message with the query flag set when in PASSIVE 
state, said node modifies said node's tables and sends back an update message with 
the reply flag set; and 

wherein if a node receives a message with the query flag set when in ACTIVE 
stage, sard node modifies said node's tables and sends back an empty message with 
no updates and with the reply flag set. 
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